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(57) Abstract 

A transaction based interactive televi- 
sion system (20) includes an insertion system 
(22) for inserting in a preferred embodiment 
coded interactive information in the vertical 
blanking interval of a standard television sig- 
nal. The signal is received and decoded by a 
decoded system (24) which includes a settop 
decoder (30) which sends an infrared signal 
to a handheld device (28). The viewer using 
the handheld device (28) can interact with a 
game, sports, or educational or event or 
other presentation on television. The system 
includes proprietary high level command 
language and a proprietary set of PIU tables 
which are maintained in non-volatile memo- 
ry (74) of the handheld device (28). The PIU 

tables store the transaction of the various events presented on the television. The PIU tables allow the various events to be broken 
down into a number of transactions. Thus, for a sports event with interleaved commercials, a number of PIU tables would be used 
to store a collection of transactions used for the main event and additional PIU tables are used for storing transactions for each 
of the various interleaved commercials. 
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10 T.TMITED COPYRIGHT WAIVER 

A portion of the disclosure of this patent 
document contains material (code listings and message 
listings) to which the claim of copyright protection 
is made. The copyright owner has no objection to the 

15 facsimile reproduction by any person of the patent 
document or the patent disclosure, as it appears in 
the U.S. Patent and Trademark Office file or records, 
but reserves all other rights whatsoever. 

Copyright 1991 Watch & Win 

20 

FIELD OF THE INVENTION 
The present invention is directed to an 
interactive communication system and in particular, 
one adapted for use with existing broadcast, cable, 

25 and satellite television or radio* or other 

communication systems for allowing participants and 
viewers to interact with the system in order, by way 
of example only, to shop, enter into games of skill, 
and engage in educational' presentations and other 

30 events where information is provided and the 

participant or viewer can make an appropriate response 
thereto. 

BACKGROUND OF THE INVENTION 
35 Many products have been introduced that 

provide the capability for the viewer to participate 
in television programs. These products accept cue 
signals transmitted to handheld devices that measure 
and control the response of the viewers as the viewers 
40 participate in the program. Some of these devices 
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implement hardware that monitors the response or the 
results of responses accumulated over time and reports 
the results to a central site. One of the early 
embodiments of this technology was the QUBE 
5 interactive two-way television system introduced by 
Warner Communications at least as early as 1982. 
Other systems include the INDAX system field tested at 
least as early as 1984 by Cox Communications, and the 
Interactive Networks System field tested during 1990 
10 and 1991. 

The Interactive Active Network System is at 
least in part described in U.S. Patent No. 4,592,546 
which is entitled "GAME OF SKILL PLAYABLE BY A REMOTE 
PARTICIPANTS IN CONJUNCTION WITH A LIVE EVENT " and 

15 issued on June 3, 1986. This system, in one 

embodiment, contemplates the use of the vertical 
blanking interval of the standard NTSC television 
signal for downloading to a remote viewer's handheld 
device game play or other interactive instructions . 

20 In addition over the vertical blanking interval (VBI) 
a lock-out signal can be sent to prevent scores from 
being credited after the answer to the event has been 
presented on the screen. This system demonstrates the 
capability of having the scores accumulate throughout 

25 the television presentation, then allows the final 

scores to be burst back as, for example, digital data 
over a modem after the program is completed and during 
a time interval which is significantly less than the 
total time interval of the program. 

30 All of the above products fall generally 

within one of two categories of product. The first 
category consists of software that is coded in 
firmware in a remote participant's handheld device 
where the participant can start playing along with the 

35 interactive program as soon as the programs begins. 
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The second category maintains the software in random 
access memory in the viewer's handheld device where 
the program must be downloaded into the device prior 
to the event starting. This process may require up to 
5 five minutes requiring the participant to wait prior 
to participating in the interactive program. 

Both categories of devices are designed to 
work with one interactive program at a time, where the 
participant must complete that program before being 

10 able to participate in a new program. 

When these products are compared to the 
television viewing habits of consumers, significant 
deficiencies are apparent. Most viewers do not 
continuously watch one program. Viewers generally 

15 switch between several channels. This is so pervasive 
in the industry that the term "grazing" has been given 
to the habit of switching between channels during the 
programs . 

20 SUMMARY OF THE I NVENTION 

An interactive system concept that is 
compatible with the participants viewing habits is 
required for interactive television to be successful. 
This system must include the ability to maintain 

25 several interactive programs active at the same time 
and not require advance downloading of programs or 
initialization information. When the viewer tunes the 
channel, the viewer is immediately able to participate 
in the interactive program either if the viewer is for 

30 the first time watching that program or the viewer is 
returning after watching some other program for a 
brief or extended period. 

In the situation where a viewer returns to a 
program that was previously watched, the interactive 

3 5 game continues, leaving out only the part that was 
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missed. Any cumulative score for the part of the 
event actually particpated in can be entered. The 
result would be the same as if the missed questions 
were not answered. 

The present invention is designed to overcome 
the problems and disadvantages associated with the 
prior art and to address the way participants actually 
view television events. In particular, the present 
invention provides for a transaction based system 
whereby the various interactions, which can occur over 
a period time, between the system and the viewer, can 
be broken down into and defined by a plurality of 
transactions. 'The transactions are stored in 
programmer (PIU) tables which are identified by 
15 programmer identification (PID) numbers and which are 
provided in non-volatile memory in, for an example, a 
handheld device used by the viewer to interact with 
the television presentation. Data to update and 
reprogram each of the tables is supplied, in a 
20 preferred embodiment, over the vertical blanking 
interval in conjunction with the television 
presentation. Once the structure of the PIU table is 
established, the game can then be initiated through a 
high level command language which is sent over and 
25 incorporated in succeeding VBI lines in order to 
initiate the various transactions. 

With a transaction based system, multiple 
games and interactions dealing with different subject 
matter can be accomplished in an interleaved manner. 
30 For example, during an hour long television 

presentation, a number of transactions can be strung 
together in order to interact with a continuous theme 
being presented in the main programming for that hour. 
Additionally, should the main programming be broken 
3 5 down into sections, the transactions can be grouped in 
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as many groupings as necessary in orde'r to represent 
the desired interactivity with each portion of the 
main program. Still in addition, the present system 
has the capability of allowing, for example, a 
5 transaction or grouping of transactions to take place 
for each of the multiple commercials which are spread 
throughout the main presentation. Thus, the present 
system affords the ability for the viewer to play and 
interact with multiple transactions which can be 
10 associated with totally different interactive 

presentations on the screen and have all of the 
interactions properly recorded and scored. As each of 
PIU tables can be established through the use of only 
a few VBI lines, the system allows a viewer to begin 
15 playing a game or interacting with the television 

presentation during any portion of the presentation 
and also allows the viewer to switch channels or 
"graze" and still be immediately able to play or 
interact with any game or presentation presently 
20 presented on the newest selected channel. 

This ability presents a significant advantage 
over the prior art which requires, as indicated above, 
that the viewer pretune to a specific channel ahead of 
the game so that the necessary game software can be 
25 downloaded, over a significant interval of time, into 
the remote terminal before the game can be commenced. 
Further, such prior devices only afford the viewer the 
ability to play or interact with a single game or main 
event at a time without the ability to switch between 
events interleaved on the same channel, as for 
example, between the main event and commercials, or to 
switch to other channels and be able to interact with 
the event of that channel and have the results scored. 
Such grazing would not be available with prior devices 
due to the fact that a remote terminal would not have 
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been properly programmed. In fact, should the viewer 
change channels, with prior devices the viewer would 
then not be able to interact with the event on that 
channel until the next event began or would have to 
wait for the software for that particular event to be 
downloaded before commencing with the interactivity. 

Accordingly, the present invention provides 
for an interactive presentation system which comprises 
a device for receiving at a remote location 
interactive data in assocation with the presentation 
of an event. The interactive presentation system 
further includes a device for defining transaction 
structures for allowing the interactive active data to 
be communicated only as needed for each particular 
aspect of an event, and throughout the event such that 
there is no interruption of the event. Further, the 
transaction structures allow for events and aspects 
within each event to be interleaved while maintaining 
interactivity with each. even. The system further 
includes a device for reporting the results of the 

interactivity. 

The receiver mechanism of the present 
invention also includes a settop decoder for decoding 
interactive data received in conjunction with a signal 
25 of the event. The receiver device additionally 

includes a handheld terminal for allowing the user to 
interact with the event and a mechanism for providing 
communciation between the settop decoder and the 

handheld terminal. 

In another aspect of the invention, the 
transaction structure includes a device for storing 
identification for each of the plurality of 
transaction tables and a device for storing at least a 
portion of the interactive data and a user response to 
the interactive data. 
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In another aspect of the invention, the 
interactive data includes interactive commands/ and 
also event specific data associated with each specific 
event or aspect of each event. 
5 In yet another aspect of the invention, the 

receiving device includes a message display and the 
interactive commands cause messages to be displayed on 
the message display. 

Yet in a further aspect of the invention, the 

10 receiving device can receive messages to be displayed 
and the transaction structure can store received 
messages. The interactive commands are for 
additionally causing either a received message or a 
stored message to be displayed in order to initiate or 

15 to continue with an interactive presentation. 

Thus, with the present invention, the viewer 
is afforded the ability of interacting with a 
multiplicity of interleaved events, the ability to 
stop and start the interactivity at the viewers time 

20 of chosing, the ability to select events offered on a 
multiplicity of channels and to interact within a time 
period and in the order desired by the viewer and to 
have all of the responses for the various events 
scored and stored for the portion participated in by 

25 the viewer. 

BRIEF DESCRIPTION OF THE FIGURES 
Fig. 1 depicts a schematical representation 
of an embodiment of the inserting system and the 
30 decoding system of an embodiment of the transaction 

based interactive television system of the invention. 

Fig. 2 depicts the format of a line of data 
in the vertical blanking interval. 

Fig. 3 depicts the data spacing for the data 
35 of Fig. 2. 
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Fig- 4 depicts the IR data stream embodied as 
an FSK biphase encoded data stream. 

Fig- 5 depicts a more detailed schematical 
representation of the settop decoder of Fig. 1. 
5 Fig- 6 depicts a more detailed schematic 

representation of the handheld device or terminal of 
Fig. 1- 

Fig- 7 depicts a schematical representation 
of the IR detector of the handheld device of the 
10 receiver of the system. 

Fig. 8 depicts a top plan view of a "T" 
shaped handheld device of an embodiment of the 

invention of Fig- 1- 

Fig. 9 depicts an embodiment of a keypad 

15 layout for the device of Fig. 8. 

Fig. 10. depicts a representation of the IR 
coverage area for the invention of Fig. 1. 

Fig. 11 depicts an embodiment of the memory 
map of the static RAM of an embodiment of the handheld 
20 terminal of the invention of Fig. 1. 

Fig. 12 depicts a schematical representation 
of the static RAM interface of an embodiment of the 
handheld terminal of the invention of Fig. 1. 

25 n ^rr.Bn n p e^TPTTnw o* preferred EMBODIMENT 

TP&HS&CTIO H RASED I MTWP ACTIVE SYSTEM: 

An interactive system 20 (Fig. 1) of the 
invention that includes the capability of allowing the 
viewer to participate with interactive television 
30 programs on many channels is best implemented by 

transmitting the interactive control information along 
with the television program. 

One of the recognized approaches to transmit 
data in conjunction with a television video signals 
35 to insert the data in lines 10 through 20 of the 



is 



SUBSTITUTE SHEET 



WO 93/10605 



PCT7US92/09455 



-9- 



vertical blanking interval (VBI). An example of this 
method of transmitting data is closed captioning 
information which inserts data on line 2 1 of the VBI. 

The system 20 has the data inserted with an 
5 insertion system 22 on the VBI of the program material 
prior to broadcasts and decoded with a decoding system 
24 for the participant^ watching the program. At each 
receiving location 26 , the data must be recoved from 
- the VBI by the decoding system 24 which includes a 

10 decoder 30 and a handheld device 28, with the decoder 
30 transmitting data to the handheld device 28 which 
is required to be used in order to participate in the 
interactive event . 

Marketing considerations dictate that the 

15 settop data converter or decoder 30 decodes the VBI 

information and transmits the interactive data via an 
infrared transmission device 32 to the handheld device 
28. Using IR transmission, the participant may move 
freely about the room keeping the handheld device 2 8 

20 pointed in the general direction of the settop data 
converter 30. 

The video tape recorder 34 of the insertion 
system 22 is used to play the source program of 
interest. This program may be a live event, and in 

25 that situation, a camera is substituted for the tape 
recorder. The output of the tape recorder 34 is a 
NTSC video and sound signal which can be transmitted 
through a video delivery system such as a cable or 
conventional television broadcast system 36 to a 

30 multiple of remote locations , for example, homes. 

The NTSC video output signal is supplied to a 
standard data bridge luminance inserter 3 8 which 
includes the capability to insert luminance modulated 
data on horizontal blanking interval lines within the 

35 vertical blanking interval. The interactive data to 
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be inserted is provided by a computer 40 which 
synchronizes this data using a conventional frame 
grabber card 42 providing hardware interrupts for the 
vertical and horizontal blanking intervals of the 
5 program material from the VTR 34. The format of a 
horizontal line 44 of data is shown in Fig. 2. 

One format for data transmitted within the 
VBI that is both well documented and is considered to 
be reliable is the format chosen for closed captioning 

10 information. This format transmits a burst of data 
46 , preceded by a start bit 45, driving one line of 
the VBI and located between synchronization pulse 48. 
A color burst signal 47 and a clock run-in signal 49 
are also depicted. Each burst is repeated at the 

15 television field rate of 16.67 milliseconds Fig. 3. 

This data format provides for 14 -bits of data with a 
parity bit every seven bits. 

Any conventional data format is acceptable 
with the understanding that the data may be inserted 

20 on blank lines within the vertical blanking interval. 
The output signal from the luminance or VITS inserter 
38 is transmitted over any conventional television 
distribution system including a broadcast, satellite 
or cable delivery system. The individual television 

25 channel carrying the program is selected using a 

conventional TV turner as found in a television or 
consumer VCR 50. If a VCR is used as the turner, the 
VCR contains a demodulator to provide a baseband video 
output containing the video of the program from VTR 34 

30 and the interactive data inserted by the luminance or 
VITS inserter 38. 

The video signal is processed using, for 
example, a conventional VBI data removal circuit 52 to 
create a data stream 54 identical to the inserted 

35 interaction data stream. 



3NSDOCI0: <WO 931060SAI_L> 



SUBSTITUTE SHEET 



WO 93/10605 



PCT/LS92/09455 



-11- 



For reliable transmission using infrared as a 
transmission system, the data rate in a preferred 
embodiment does not exceed 3,000-bits per second. The 
VBI data is recovered at a data rate of 500,000-bits 
5 per second. However, this rate occurs for a short 
burst during the vertical blanking interval. Thus, 
while active video is being transmitted, interactive 
data is recovered from the program source. 

10 Settort Decoder or Co nverter 30: 

The purpose of the settop converter 30 is to 
recover the data transmitted during the VBI at a high 
data rate and, using infrared, transmit that same 
information to the handheld device 28 at a much slower 

15 data rate of 3,000-bits per second. This can be 
solved using a first-in-first-out buffer 56 with 
different clocks for the input and output functions. 

The serial data stream is stored in the 
first-in-first-out buffer 56. Each group of 14-bits 

20 of data from a horizontal line 44 in the VBI is stored 
at the transmitted data rate of 500,000-bits per 
second. Since a specific horizontal line only occurs 
every 16.7 milliseconds, the data stream consists of 
14-bits clocked at a high rate followed by 16.7 

25 milliseconds of no data as shown in Fig. 3. 

The output of the first-in-first-out buffer 
56 is clocked at a data bit rate of 3,000-bits per 
second. Using this rate, the 14-bits are transmitted 
within 4.7 milliseconds as shown in Fig. 3. 

30 The slower output rate from the first-in- 

first-out buffer 56 is necessary to insure that the 
output bit time is compatible with transmitting the 
data using an infrared modulator. 

The infrared modulator or transmitter 3 2 

35 consists of two oscillators running at a multiple of 
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3 ,000 Hz, with each phase locked to the output clock 
rate. If the bit from the buffer is a "1", oscillator 
1 is selected to drive the IR transmitter. If the bit 
is a »0», oscillator 2 is selected to drive the IR 
transmitter. Using this FSK encoded data stream 
approach (Fig. 4), the IR transmitter radiates IR 
energy at a frequency determined by the serial data 
clocked out of the first-in- first-out buffer. 

Thus from the above, it is evident that the 
interactive system includes a device for delivering 
one way low speed digital data to a handheld device 
that can be used to participate in interactive 
television programs . 

Figure 5 depicts a more detailed schematical 
15 representation of the settop decoder 30 of the system 
as shown in Fig. 1. This settop decoder 30 is 
substantially similar to a conventional decoder for 
decoding VBI information used, for example, for closed 
caption applications. Additionally settop decoder 30 
includes the IR modulator or transmitter 32 as 
described above. Viewing Fig. 5, it can be seen that 
the settop decoder 30 includes a synchronization 
detector and line counter 60 which receives the 
broadcast signal. Further, the settop decoder 30 
includes a data recovery and jitter correction unit 
62. These units 60, 62 communicate with the 
microprocessor 54 for causing the microprocessor 64 to 
latch VBI data to the register or first-in-first-out 
buffer 56. From buffer 56, the data is communicated 
to the FSK modulator and IR drive 66 and therefrom to 
the IR diode array 68. The FSK modulator and IR 
driver 66 and the IR diode array 68 comprise the IR 
transmitter 32. 
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Handheld D evice or Terminal 28: 

The handheld interactive terminal 28 provides 
the means to participate in the interactive program. 
It decodes the data stream from the settop converter 
5 30 and implements the interactive program. 

The hardware modules within the handheld 
device 26 consist of an infrared photo detector 70 to 
sense the IR signal from the settop converter 30, a 
microprocessor 72 with a control program, which can 

10 implement the command code discussed below stored in 
an on-board ROM, a RAM 74 including both non-volatile 
and temporary storage for information sent via the IR 
link, a keyboard 76 for data entry, a clock circuit 78 
to track actual time, and a LCD display 80. A block 

15 diagram of the handheld device is shown Figs. 1 and 6. 

The IR receiver or detector 70 has a circuit 
82 which consists of a photo diode 84 providing an 
electrical voltage proportional to the IR light level 
and a frequency discriminator 86 detecting the FSK 

20 modulation of the IR signal (Fig. 7). 

The output of the photo detector 84 is 
amplified and shaped to provide a square wave with the 
frequency identical to the frequency of the IR signal. 
This frequency modulated signal is supplied to the 

25 frequency discriminator 86 tuned to the two 

frequencies used to transmit the IR data. This 
discriminator 86 recovers the serial data and supplies 
it to the microprocessor 72 of the handheld device 28. 
The microprocessor 72 monitors the serial 

30 data transmitted via the IR link and builds a command 
stream from this data as defined in the below section 
describing the software structure of the invention. 
The commands create an operating program that 
implements an interactive program for the participant. 

35 The ROM of the microprocessor 72 contains the control 
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program and command interpreter for the commands sent 
on the VBI. The RAM memory 74 stores the data and 
commands transmitted over the IR link representing the 

interactive program. 

Figure 8 shows an example for the «T« shaped 
case for the handheld device 28. Aspects of the outer 
housing 94 of the handheld device 28 include the 
following. 

The case 74 is made from molded plastic of a 
strength and texture suitable for use by consumers in 
a household environment. 

The keypad 76 should be a 1 -piece molded 
rubber type with carbon contacts that make switch 
connections against a switch pattern on a printed 
circuit board (PCB) . The words under nine of the keys 
(YES , NO, TRUE, FALSE, POOR, FAIR, AVERAGE , GOOD, 
EXCELLENT) are part of the plastic case 94 and not 
part of the keypad 76. The keypad 76 is arranged as 
four rows times five columns. Figure 9 shows the 
arrangement and names all twenty keys . 

The handheld device 28 derives power, in a 
preferred embodiment, from four 'AA' size cells that 
must be replaceable by the consumer via a removable 
door on the back of the unit. 

The IR receiver 70 will have two windows of 
red tinted plastic that filter visible light in the 
front left and right corners of the case. IR receive 
circuitry will be mounted on the PCB behind both of 

these windows . 

The "T" shape device 28 accommodates a 
relatively wide LCD display 80 (approximately four 
inches) and a relatively narrow keypad 76 into a 
package that can be either set on a table or held in a 
consumer ' s hand . 
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The microprocessor 72 includes, in a 
preferred embodiment, a Mitsubishi M38002M2-FP with 
8K-bytes of internal ROM in a plastic quad flat pack 
package. The microprocessor 72 operates in a memory 
expansion mode at a crystal frequency of 5MHz crystal 

The assignments of I/O pins to specific 
functions are shown in Table 1 below. 

TABLE 1: MICROPROCESSOR I/O PIN ASSIGNMENTS 



PQFP 
PIN NUMBER 

56 
3 
2 
1 

64 
63 
62 
61 
60 

11 

21 
20 
10 

9 

8 

55 
58 
59 

12 
14 
15 
17 
16 
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PIN NAME DESCRIPTION 

P30 Column 5 Keypad Scan Output 

P60 Column 4 Keypad Scan Output 

P61 Column 3 Keypad Scan Output 

P62 Column 2 Keypad Scan Output 

P63 Column 1 Keypad Scan Output 

P64 Row 4 Keypad Scan Input 

P65 Row 3 Keypad Scan Input 

P66 Row 2 Keypad Scan Input 

P67 Row 1 Keypad Scan Input 

INT2 Active Low Keypad Key Hit Interrupt 

P40 Real-Time Data 

P41 Real-Time Output Enable 

P51 Real-Time Clock 

P52 Real-Time S1 - 

P53 Real-Time S2- 

P31 LCD Contrast MSB 

P71 LCD Contrast 

P70 LCD Contrast LSB 

SRDY- Not Used 

TXD Not Used 

RXD Serial NRZ Data From IR Receiver 

INTO Carrier Detect (Any Level) 

INT1 IR Data Clock (Rising Edge, Tie to 

SCLK) 

SCLK IR Data Clock (Rising Edge, Tie to 

INT1) 

P57 LCD Power Enable/Disable 

(ENABLE =0) 
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50 



5 
6 
7 



48 
47 
46 
45 
44 
43 
42 
41 
40 
39 
38 
37 
36 
35 
34 
33 

32 
31 
30 
29 
28 
27 
26 
25 

49 
50 
51 
52 
53 
54 

22 
23 

19 

18 

24 
57 



P56 
P55 
P54 



ADO 

AD1 

AD2 

AD3 

AD4 

AD5 

AD6 

AD7 

AD8 

AD9 

AD10 

AD11 

AD12 

AD13 

AD14 

AD15 

DBO 
DB1 
DB2 
DB3 
DB4 
DB5 
DB6 
DB7 

RD- 
WR- 
SYNC 
PHI 

RESETOUT- 
ONW- 

XIN 
XOUT 

RESET- 

CNVSS 

VSS 
VCC 



Low Battery Input 

32K-Byte Static RAM Write Protect 

Piezoelectric Speaker Output 
(Pulses) 



Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 



Bus 0 
Bus 1 
Bus 2 
Bus 3 
Bus 4 
Bus 5 
Bus 6 
Bus 7 
Bus 8 
Bus 9 
Bus 10 
Bus 11 
Bus 12 
Bus 13 
Bus 14 
Bus 15 



Data Bus 0 
Data Bus 1 
Data Bus 2 
Data Bus 3 
Data Bus 4 
Data Bus 5 
Data Bus 6 
Data Bus 7 

Read Strobe to Static RAM 

Write Strobe to Static RAM and LCD 

Not Used 

Not Used 

Not Used 

1 Wait State for LCD 

Connect 5MHZ Crystal 
Circuit Across XIN/XOUT 

Active Low Rest From Power Detect 

Connect to VSS for Internal ROM 

VSS from Battery - 
VDD from Battery + 
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The keypad 76 is scanned by the 
microprocessor using five outputs and four inputs. 
The four inputs are diode-or'ed together such that any 
keypress will produce an interrupt to the 
5 microprocessor. These active low interrupts occur 
when a key is pressed. 

The handheld device 28 receives all remote 
data from the settop unit 30 via an infrared (IR) data 
link. The performance of this link must have a bit 

10 error rate less than one error for every 100,000-bits 
transmitted (random bit errors) when in the 
configuration shown in Fig 10. In this configuration, 
the handheld receiver 28 is 7.6m (25 feet) from the 
transmitter of the settop converter 30 and anywhere 

15 within plus or minus 60 degrees of the centerline of 
the transmitter. 

As indicated above, the physical format of 
the IR data is an encoded FSK signal. The lower 
frequency is a 49KHz and the upper frequency will be 

20 5 9 KHz . The data rate is a 3000 bits/seconds (BPS). 
Figure 4 shows the format of this data. The first 
line is the digital clock. The second line is the 
stream of digital IR data. The third line is the 
equivalent line mid-bit transition encoded data and 

25 the fourth lines shows the data FSK encoded. The FSK 
data is applied to the IR transmitting LEDs on the 
settop unit 30 and received by the diodes in the 
handheld device 28. The FSK data is decoded into mid- 
bit transition data, from which a clock is extracted 

30 and the data returned to the digital format. The 
microprocessor 72 uses the clock to shift the data 
into an internal serial port running in the 
synchronous mode. As indicated previously, the clock 
that is extracted as shown on the first line (Fig. 4) 

35 and is called the digital data clock. 
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To minimize power consumption, the IR 
receiver 70 should be preceded by a carrier detect 
(CD) filter 96 (Fig. 6). When energy in the 46-62KHZ 
range is detected then the carrier defect filter 
said to be active. This signal will actually switch 
power to the IR receiver with a VDD switch (a MOS 
transistor gate circuit in a preferred embodiment) 
which will remain powered while the IR data is 
received. After the IR data transmission from the 
settop unit 30 is complete the CD signal will go 
inactive and will remove power from the IR receiver 
70 The CD filters 96 consumes as little current as 
possible since it is active all of the time. The 
logic level of the CD signal is a "don't care" for the 
microprocessor 72 and is chosen based on the lowest 
power consumption or cost of the CD circuit. 



g^p-frSc RAM: 

Figure 11 shows the memory map of the 32K- 
byte static RAM 74. The static RAM 74 will be decoded 
into microprocessor addressees OOOOh to 7FFFh . The 
first 400h locations of the external RAM 74 will be 
unused since these locations are internal to the 
microprocessor. The static RAM must run with zero 

25 wait states. 

Figure 12 shows the 32K-byte static RAM 
interface 98. It is important that the chip select 
(CE-) pin of the RAM be higher than VDD-0 . 2 when not 
being accessed in order to be in the lowest power 
mode. This is the reason for the transistor circuit 
100 at the CE- pin in Figure 12. This extremely low 
power mode is found on the latest currently available 
versions of static RAM chips and results in a current 
draw of about 2uA at room temperature. 
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The static RAM 74 chip (like the real-time 
clock) will be powered by the power fail detect 
circuitry 78 that changes over to the lithium coin 
cell 102 when loss of power from the main four 'AA' 
5 cells 104 is detected. This power is referred to as 

VDDsafe in Fig. 6. 

The 32K-byte static RAM 74 has write protect 
circuitry 106 that requires the microprocessor 72 to 
place a logic low on an I/O pin before any write 

10 operation can be performed and will prevent false 
writes to the static RAM 74 during reset (which is 
active whenever VDD is invalid) . The write protect 
circuit 106 is also powered by VDDsafe. It is noted 
that address bus lines AD14 and AD15 are pulled up to 

15 VDD for the memory address decoding to work properly. 

The LCD display 80 is a two line by 24- 
character display with built in display RAM and 
character generator RAM. No backlight is used. The 
LCD display 80, in a preferred embodiment, shall 

20 conform to the features of the Sharp LM24255 

(preprogrammed character generator ROM and eight 
character generator RAM locations). 

The LCD display is mapped into memory at 
microprocessor addresses 8000h (control register) and 

25 8001h (data register). The timing of the typical LCD 
display 80 module indicates that one wait state may be 
required during accesses and the microprocessor ONW- 
line is appropriately controlled to accomplish this 
task (see Table 1). 

30 To allow the microprocessor to control the 

LCD contrast in software a R/2R ladder network is to 
be implemented using three I/O bits of the 
microprocessor (see, Table 1). 

The LCD design does not have a low power 

3 5 mode. To extend battery life, the LCD power must be 
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controlled by an I/O bit from the microprocessor. 
Figure 6 shows this as a VDD switch 18. This can be, 
in a preferred embodiment, a MOS transistor gate 
circuit that will allow power to the LCD when the 
5 microprocessor control signal is low. 

The Epson RTC-4503 chip is the preferred 
real-time clock 76. It is connected to the 
microprocessor 72 with I/O pins. The real-time clock 
76 (like the static RAM 74) is powered by the power 

10 fail detect circuitry that will change over to the 

lithium coin cell 102 when loss of power from the mam 
four ' AA' cells 104 is detected. This power is 
referred to as VDDsafe above. 

The piezoelectric speaker 88 will produce 

15 musical tunes and tones. The frequency response of 

this unit is within the range of lKHz or below on the 
low end and 5Khz or above in the high end. Within 
this range, the sound pressure output of the piezo is 
level. The sound pressure level output should be in 

20 the range of 20dB to 30dB. 

The speaker 88 is driven by one of the timer 
outputs of the microprocessor 72 running in the pulse 

output mode . 

The preferred main source of power is four 
25 'AA' cells 104. There is an additional three volt 

lithium coin cell 102 that powers the 32K-byte static 
RAM 74, write protect circuitry 110, and the real- 
time clock 78 when loss of main power is detected 
since these must remain powered at all times . Main 
power is lost when the four ' AA' cells are either 
drained below minimum working voltage or are removed 
entirely. The power derived only from the main 
batteries is referred to as VDD. The power that is 
output from the power fail detect circuitry that is 



30 
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powered by the three volt lithium coin cell is 
referred to as VDDsafe as indicated above. 

SOFTWARE STRUCTURE : 
5 The features of a particular interactive 

program are implemented in part in software resident 
in the handheld terminal 28. This software performs 
two functions. The first function is to build a short 
interactive program from high level commands 

10 transmitted via the IR link. After the program has 
been transmitted and verified by a CRC error check, 
the software enables the program to be executed. The 
second function is the execution of the program. Each 
independent program that is transmitted and executed 

15 is called a transaction. A typical transaction would 
consist of a sequence of a question asking for a 
response from the participant followed by a test of 
the response resulting in a score. 

During the time that the participant is 

20 responding to the transaction, the next transaction is 
being received and made ready for the participant to 
process. Using this approach, the amount of 
information transmitted via the network prior to a 
participant being able to use the handheld device 28 

25 is essentially transparent to the user compared to 
other prior interactive devices. 

Timed responses where the participant must 
react within a specific time interval is controlled 
either by a countdown timer implemented with the 

30 microprocessor 74 within the handheld terminal 2 8 or 
via a new transaction being sent and activated before 
the participant enters the response to the prior 
question* 

For a question where the viewer has a 
3 5 predetermined amount of time to provide an answer, the 
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input command requesting the answer includes a time in 
seconds that the handheld device 28 waits for user 
input . 

After completing an interactive game, a 
resulting score is encoded with the program code and a 
box serial ID number to establish an authorization 
number unique for the viewer. Using a touch tone 
telephone, the viewer may enter their results for 
prizes or recognition. 

Transm^ tP.^ via the. IR Link: 
The interactive programs and messages are 
transmitted over the IR link in a data format 
structured as a packet containing all of the 
interactive commands required for a participant to use 
the handheld device 28. The structure of this packet 

is as follows: 

Syno 3 -bytes of all ones 

Packet ID 3 -bytes 

Packet Count 2 -byte 

Command 1 



Interactive Program 
2 -bytes 

End of Frame 3 -bytes of all zones 



Command _ 
CRC 2 -bytes 



The sync block and end of frame block are 
three-bytes with a bit pattern that is unique within 
30 the packet. This approach clearly defines the start 
and end of each packet. 

The packet ID consists of 24-bits (3-bytes) 
with the bits segmented into a programmer ID of 9- 
bits, a program ID of 12-bits, and a PIU slot address 

35 of 3-bits. 

The PIU table (200 of which are located in 
RAM 74) where data is stored corresponds to an unique 
PIU code. Each programmer as defined by the 
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programmer ID has a specified number of tables 
available for their use. The PIU slot address defines 
which table within the programmer's set of table may 
be used by the interactive program. 
5 The software process within the handheld 

device 28 consists of the packet being received 
correctly over the IR link. The programmer ID and the 
slot address is used to select a PIU table. If a 
table does not exist with the same programmer ID and 

10 slot address, a new table is created. If the table 
exists and the programmer ID is the same for the new 
transaction compared to the stored ID in the table, 
the old values in the table are kept and the 
interactive commands transmitted within the packet are 

15 processed. If the new program ID of the table are 
different, the table values are erased before 
processing the packet. 

The command structure is encrypted using a 
conventional FEC algorithm with one half rate coding 

20 to improve data transmission reliability. It is also 
encrypted using a key ranging up to 56-bits. Within 
the handheld device 28, a total of three keys are 
stored. A command to modify the third key is defined 
and is available for changing the key in the event the 

25 three keys become known. 

Interactive Software Commands : 

In order to reduce the time required to send 
an interactive program via the IR link, a high level 
30 interactive language was invented. This concept 

reduces the amount of data that must be transmitted to 
a few powerful commands. The specific order and 
collection of these commands within the packet 
determine the interactive program. The user's 
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response to these commands implement the interactive 
program. 

An interactive program consists of one or 
more packets of commands that are sent via the IR link 
and processed by the control program of the handheld 
device 28. Each handheld device 28 contains the 
interactive program transmitted via the IR link and 
can generate a score or response unique to the 
individual participant. 



rvypyi-irrht ® & Win: 

COMMANDS The handheld device implements 

transactions, events, and PIUs through 
interpreting a set of commands inserted 
by programmers at the insertion system 
22 and transmitted over the data path 
by, for example, broadcast signals, to 
decoding system 24. These commands are 
created by the programmer using a 
software package provided with the 
insertion system 22. The following 
commands represent the main types of 
functions that are implemented. Table 2 
attached, includes a further list of 
25 commands. 

Display (msg) The message is displayed on the LCD and 
remains on the LCD display until one of 
the following conditions or events 

3 q occurs: 

Another message is processed. 

The Recall button is pressed. 

Other special massages are 

displayed if the appropriate button 
32 is pressed. 
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No data is transmitted to the 
handheld within 15 seconds and the 
viewer has not pressed any buttons 
(at which time the handheld device 
5 powers down) . 

If the viewer attempts an invalid input, 
the display does not change. 

Input (msg) The message is displayed and the unit 

10 waits for input as described below: 

A time delay INPUT (msg, counter) 
request is one where the amount of 
time in seconds is transmitted 
along with the input command. For 

15 timed input, while waiting for the 

counter to reach zero, the two (or 
three) digit time value is 
displayed in the bottom right two 
(or three) screen display 

20 characters. 

If the counter times out before any 
input by the viewer, the handheld 
device displays MSG1. 
An open ended INPUT (msg) request 

25 is one where the unit waits for 

input until the next transaction is 
received. 

If the viewer provides a response 
after the next transaction is 
30 received, the response is ignored 

and the transaction containing the 
INPUT command is flushed from the 
unit. Alternatively, the last 
response could be interpreted as a 
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response to the next subsequent 

transaction . 
The handheld device waits until the 
enter key is pressed before processing 
the response. The number of keys 
entered from the keyboard can be limited 
by the field width variable. If the 
field width is one, then an enter key is 
not needed to terminate an input 
response. If the Timeout variable is 
not zero, then the input command will be 
timed. If the timer expires, the 
command will automatically terminate and 
the input response ignored. 
Example: 

INPUT "How much are you willing to 
bet?", 3, 33 

[OPCODE] [Field Width] [X Offset] 
[String] [Null] 

INPUT "How much are you willing to 
bet?", 3, 33, 10 

[OPCODE] [Field Width] [X Offset] 
[Timeout] [String] [Null] 

Range (x,y) Associated with the INPUT command 

prescribing the range of acceptable key 
inputs that is the range of value that 
are acceptable as answers . When the 
viewer response is detected, the unit 
confirms that the response is within the 
range and processes the next command 
within the transaction. 
If the response is not between "x" and 
"y" values, the unit displays MSG2 and 
waits for a new input. If the second 
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response is still not within the range, 
the unit displays MSG3, clears the input 
buffer and processes the next command. 
Example: 
5 RANGE TO, Tl 

[OPCODE] [LOW REGISTER] [HIGH REGISTER] 

(3-bytes) 
RANGE 1 , 2 

[OPCODE] [LOW VALUE] [HIGH VALUE] 
10 (9-bytes) 

Add (x,y) The programmer can add the value in 

location x to the value in location 

y, where the sum is stored in 
15 location y. 

Sub (x,y) The programmer can subtract the 

value in location x from the value 
in location y, where the result is 
20 stored in location y. 

Save (x,y) The programmer can save the value in 

location x (or a value itself) in 
location y. The previous value in 
25 location y is lost. 

CONDITIONAL: 

If, Then, The programmer can establish logic 

and 

30 And, Or arithmetic function using >,(,)=, < = 

And, Or or = as a test of either keyed input, 

stored responses, or stored scores to do 
other logic steps. A typical example is 
as follows: 

3 5 Example: 
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IF TSCORE > THEN DISPLAY "Good Work!" 
IF (RESP 1 == TO) THEN 

[OPCODE] [Operator] [Operand A] [Operand 
B] [True Offset] [False Offset] 
5 IF (RESP 1 == TO and (RESP 2 == Tl) THEN 

[OPCODE] [# of Op's] [Op] [OPil [OP 2 l 
[Op] [Op 3 ] [OP 4 ] [Op] [True Offset] 
[False Offset] 

" Else Used a part of IF statement to 

signify alternative processing for, 
as an example, wrong INPUT 
responses. 

Beep (x,y,z) This will generate an audio sound from 
15 the handheld device 28, where x is the 

number of beeps, y is the duration in 
seconds of each beep, and z is the 
number of seconds between each beep. 

20 Shift (x,y) This command is used to indicate a 

multiplication desired by the 
programmer. The value in location y can 
be multiplied by 2(x=l), 4(x=2) , 8(x- 
3) , or 16(x=4) . 

25 

Repeat A command which results in 

(msg x,y,z) multiple DISPLAY and other logic 

commands being sent to the handheld 
device 28. Using REPEAT, the programmer 
can request that a message be displayed 
on the handheld device 28 every x 
minutes, that the message be sent to the 
handheld device 28 every y minutes, and 
that the message stop being displayed 
35 after z minutes. 
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Hold (x) A command sent to and used by the data 

inserter 38 which tells the inserter 38 
not to insert any background information 
on line x until the line is released 
5 using a RELEASE command. 

Release (x) A command sent to and used by the data 
inserter 38 which tells the inserter 38 
that it is OK to insert background 
10 commands on line x. 

Delete (PID) This is a command used to delete the PIU 
table from non-voltage memory to make 
room for new PIUs. A background task of 
15 sending a group of DELETE commands for 

known completed PIUs will be initiated 
when it is detected that PIUs have not 
been deleted normally. 
Example : 

20 DELETE PID NUMBER 

[OPCODE] [PID NUMBER] (4-bytes) 

Prestore Stores a standard message in 

(msg, MSGx) message buffer of non-voltage memory in 
25 the handheld device 28, in location MSGx 

(MSGS - MSG10 are still available) . A 
DISPLAY command can either designate 
that a free form message or a prestored 
message be displayed on the screen. 
30 Example: 

PRESTORE 5, "Please try. again." 
[OPCODE] [MSG#] [STRING] [NULL] 
Disable Reset the handheld device 28 to its 

(boxid) uninitialized state. 

35 Example: 
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Appendcode 



DEFINE NEW 
ADDRESS KEY: 



UN- 
CONDITIONAL 

BRANCH 



DISABLE 12345678 
[OPCODE] [BOX ID] 
(5 -bytes) 

The command to add a new block of 
assembly level (exentable) code to the 
memory in the handheld device 28. 

This Opcode will load a new address key 
to be used to descramble the next 
program segment to be executed. 
Example: 
KEY 1234 

[OPCODE] [KEY] (3 -Bytes) 

This Opcode is used to transfer program 

execution to a different Opcode within 

the program. 

Example: 

GO TO LABEL 

[OPCODE] [16-Bit 2's Comp . Offset] 

(3 -bytes) 



25 



30 



35 



EXIT: 



Used to signal the software for the 
handheld device 28 that the current 
program is finished. 

Example: 
EXIT 

[OPCODE] (1-byte) 
Table 3 presents a list of prestored 



messages 



cnp^RK RpnTfiTBUft RE SIDENT IN H ANDHflT'D DEVICE 28 : 
pIU 200 PIU tables are used by the software 
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TRANSACTOR 
REGISTERS 



10 



15 



20 



to store user responses and game scores, 
The transaction register contents 
are maintained until a program 
deletes the PIU table or the 
registers are used by another 
program. The registers defined in 
each table are: 



PID 
Flag 



1 
2 
3 



Score 
Score 
Score 
RESP1 
RESP2 
RESP3 

REGISTER 1 
REGISTER 2 
REGISTER 3 
REGISTER 4 
Counter 



Programmer ID Number 
Programmable Flag 
Register 

Event Score Register 
Event Score Register 
Event Score Register 
User Response Register 
User Response register 
User Response Register 
Program Storage Register 
Program Storage Register 
Program Storage Register 
Program Storage Register 
Elapsed Timer for Viewer 
Response 



25 



SCRATCH PAD 
REGISTERS 



30 



DATE/TIME 
Date 

REGISTERS 



35 



Scratch pad registers are used by the 

program for temporary storage. The 
value of each register is cleared 
at the start of each program. 
There are 16, 32-bit registers 
available. 

Used to verify program execution 

and Time. Registers available for 

program use are: 

Minute 
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Hour 
Day 
Month 
Year 

5 

BOX ID A four-byte register that contains a 

REGISTER unique set of numbers for each handheld 

device 28. 

10 CODE A four-byte register stored in non- 

REGISTER volatile memory for global program 

usage. 

Table 4 presents an example of interactive 
15 games that can be played with this system. 

TP^iffi-T-ial ar.Pl inability 

The operation of the transaction based 
interactive television system 20 of the invention is 

20 as follows: 

in a preferred embodiment, at the programming 

or source end of the system, an event such as, for 
example, a sports event, a quiz show or an educational 
presentation is mated with interactive data in order 

25 to associate a series of inquiries and response with 
the event. The series of queries and responses are, 
in a preferred embodiment, inserted into the 
designated lines of the vertical blanking interval 
much as closed captioning signals are inserted in the 

30 VBI. Thus, the standard NTSC signal carries the 

traditional programming in addition to encoded data of 
the present invention. This signal is then 
communicated by broadcasts, satellite, cable, 
microwave or telephone lines, and any combination 

35 thereof to remote user's which have a VCR or 
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television receiver, television monitor and the 
proprietary handheld device 28 of the present 
invention. As the signals are encoded in the vertical 
blanking interval, such signals are not apparent to 
5 standard viewer at a remote location without a 

proprietary decoding system 24, which includes the 
handheld device 28 and the settop decoder 30. Thus, 
the NTSC signal is received without the viewer knowing 
or being disturbed by any other signals of the present 

10 invention. With the decoding system 24, the viewer is 
able to receive, decode, and thus interact with the 
presentation on the television screen. 

In much the same way as closed caption VBI 
decoders work, the settop decoder 30 detects the 

15 proprietary programming data recorded on the lines in 
the vertical blanking interval and decodes this data. 
The data is then transmitted through an infrared 
transmitter to a handheld device 28 which has infrared 
detectors. This signal once detected by the handheld 

20 device 28 is then used to initiate functions of the 
handheld device 28. Principal among these functions 
are the display of messages of the LCD display 80 and 
the creating and updating of the PIU tables which are 
associated with each transaction of the event. 

25 Thus, the proprietary high level command 

language transmitted in conjunction with the a 
standard television broadcast signal is used to 
activate the handheld device 28. This command 
language is used to cause the executable code also 

30 send over the VBI to fill in the PIU tables stored in 
the handheld device in order to update and create new 
transactions, to perform the various message functions 
of the handheld device, and to initiate the various 
transactions. Such an arrangement eliminates the need 

3 5 for the viewer (1) to wait for the downloading of main 
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programs and (2) to be tuned to the appropriate 
stations before the game begins in order to obtain the 

entire game program. 

The high level proprietary language affords 
5 commands and also allows for a rapid deliver of 

executable code which resides in the PIU tables. Each 
programmer or program creater at the PIU insertion 
system 24 would have its own program or ID number and 
the ID number of a number of PIU tables. Thus, the 

10 programmer can insert, at any time, in the VBI new 
information needs to go into the PIU table. As 
explained above, each PIU table includes a transaction 
for at least one response to an interactive inquiry 
from the programmer. Each of these transactions can 

15 be associated with a different game or event occunng 
throughout the programming and a number of these 
transactions or PIU tables can be linked together in 
order to create a series of continuous interactive 
transactions throughout an interactive session. For 

20 example, in the situation of a commercial broadcast of 
a live sports event with interleaved commercials, a 
number of PIU tables can be associated together to 
present interactivity throughout the length of the 
sports event. Further interleaved with the activity 

25 of the main sports event, the various commercials can 
each be assigned their own PIU table and interleaved 
throughout the main interactive event. Thus, the 
viewer can interact with the transactions of the main 
event and also interact with the transactions of each 

30 of the separate commercial events and have all the 
scores and responses recorded. 

It is noted from the above that the 
implementation of the PIU tables breaks down the games 
and events into individual transactions. These tables 

35 can be quickly created from information encoded on the 
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VBI. Tables as indicated above, are identified with a 
programmer ID. The tables are maintained in, for 
example, the static RAM as long as need. Should the 
games change, the programmer simply sends a new signal 
5 in order to reprogram that location in the static RAM. 
In the present embodiment there are several hundred 
tables, and each is capable of allowing the user to 
play a game. Thus for a game on a commercial, each 
game would have its own PIU table and main game played 
10 with the main feature would have a multiplicity of PIU 
tables. 

It follows from the above that the present 
embodiment allows the viewer to come in at any time 
during the program and immediately begin to play games 

15 or otherwise interact with the television and also to 
"graze" or switch between several stations and 
immediately be able to play or interact with each 
channel. This is an improvement over the prior art 
devices which require that only one game at a time be 

20 played, that the user wait for the information to be 
downloaded to the system, and that does not allow for 
the interleaving of various games. Further, prior art 
devices cannot allow the viewer to begin or leave the 
game at any point in time and have the score for the 

25 portion of the game played recorded. 

Even with interleaved games and with viewer's 
coming and leaving the screen at various times, the 
viewer's reactions and answers to all games in which 
the viewer participates are stored by the system and 

30 later reported to a central processing station. 

Finally, after the events are concluded, the 
viewer will receive a score or scores from the 
handheld device 28. The score is encoded along with, 
for example, the user identification number and the 

35 identification number of the handheld device 28. The 
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10 



15 



viewer can then telephone a central processing station 
and with the use of a touch tone telephone key in the 
score and the identification information received from 

the handheld device 28. 

It is further to be understood that the 
present system can be encrypted using encryption 
algorithms and keys as is known in the trade. The 
handheld device 28 would thus store, for example, 
three keys at least one of which could be reprogrammed 
by a signal sent on the VBI . 

It should also be appreciated that with the 
present system that a series of events can be linked 
together. For example, the system can afford the 
viewer the ability to participate in an interactive 
event which strings together the four or more games of 
a world series baseball event. That is to say that 
the viewer is asked to the pick the winner of each of 
the games of a world series and the winner of the 
world series. This information could be stored in the 
handheld device 28 over a period of days or longer if 
necessary for other games and then checked against the 
actual outcome of the individual games and series. 
The user's score over a period of time could then be 
encoded and then reported back to the central station 

25 by the users. 

Other aspects and embodiments of the present 
invention can be viewed from a view of the figures and 
a review of the claims . 

It is to be understood that other embodiments 
of the present invention could be configured and come 
within scope and spirit of the appended claims. 



20 



30 
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Table 2 Instruction Set Summary- 
Description 



Bvtes 


Opcode 


3 


80h 


6 


90h 


3 


8lh 


6 


9lh 


2 


71h 


4 


70h 


2 


20h 


5 


A4h 


* 


A5h 


3 


82h 


6 


92h 


4 


AOh 


1 


• A2h 


3 


A7h 


8/13 


A9h 


* * * 


50h 


3 


A3h 


1 


A8h 


3 


83h 


6 


93h 


3 


84h 


6 


94h 


3 


85h 


6 


95 h 


3 


86h 


6 


96h 


m m 


A6h 




8Bh 


9 


Alh 


1 
i 


lXh 


1 


lXh 


3 


87h 


r 
0 


97n 


3 


88h 


6 


98h 


3 


89h 


6 


99h 


5 


60h 


3 


8Ah 


6 


9Ah 



ADD 

ADDI 

AND 

AND I 

BEEP 

BEEPI 

CLR 

DISABLE 

DISPLAY 

DIV 

DIVT 

DPT 

EXIT 

GOTO 

IF 

INPUT 

KEY 

LOCK 

MOD 

MODI 

MOV 

MOVI 

MPY 

MPYI 

OR 

ORI 

PRESTORE 

RNG 

RNGI 

RSTF 

SETF 

SHL 

SHLI 

SHR 

SHRI 

SUB 

SUBI 

TIME 

XOR 

XORI 



Add direct 

Add immediate 

And direct 

And immediate 

Beep direct 

Beep immediate 

Clear register 

Disable handheld 

Display formatted text 

Divide direct 

Divide immediate 

Delete PIU table 

Terminate program 

Unconditional branch 

Conditional branch 

Input user response 

Define new decryption key 

Lock out user input 

Calculate remainder 

Calculate remainder immediate 

Load register 

Load register immediate 

Multiply direct 

Multiply immediate 

Or direct 

Or immediate 

Store display string 

Define input range 

Define input range immediate 

Reset bit, PIU flag register 

Set bit, PIU flag register 

Shift left direct 

Shift left immediate 

Shift right 

Shift right immediate 
Subtract direct 
Subtract immediate 
Verify real time 
Ex elusive -OR direct. 
Exclusive-OR immediate 



„, — -j " , . » «iw oiuu 5 icugui pi us, one. 

... number of bytes for the prestore command is the string length plus two. 

The number of bytes for the input command is the string leneth plus four or 
seven. r 
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Description 

Execution 
Encoding 
Script example 



38 



The contents of the destination register are added to the 
contents of the source register and the result ts stored in 
the destination register. 



Rd <- Rd + Rs 
[80h][Rd][Rs] (3 Bytes) 
TO = TO + Tl 
Before Instruction 



TO - 100 
Tl-20 



After Instruction 

TO - 120 
Tl -20 



: 2 ADDI add immediate value to register 
Description 



The contents of the destination register are added with a 
32 bit immediate value and the result is stored in the 
destination register. 



Execution 
Encoding 
Script example 



Rd <- Rd 4- Value 
[90h][Rd][Vaiue] ( 6 Bytes ) 
TO = TO -r 100 
Before Instruction 
TO - 100 



After Instruction 
TO - 200 



3 AXD and registers 
Description 

Execution 
Encoding 
Script example 



The contents of the destination register are anded with 
the contents of the source register and the result is 
stored in the destination register. 



Rd <- Rd AND Rs 
[81h][Rd][Rs] (3 Bytes) 
TO = TO AND Tl 
Before Instruction 



TO - OFOOOh 
Tl - 7000h 



After Instruction 

TO - 8000h 
Tl - 7000h 



SUBSTITUTE SHEET 

.9310605A1 J_> 



WO 93/10605 



PGT/US92/09455 



39 



4 ANPr and register with immediate value 
Description 



Execution 
Encoding 
Script example 



The contents of the destination register are anded with a 
32 bit immediate value and the result is stored in the 
destination register. 

Rd <-Rd AND Value 

[91h][Rd][Value] (6 Bytes) 

TO = TO AND 8000h 

Before Instruction 

TO - OCOOOh 



After Instruction 
TO - 4000h 



5 BEEP produce an audible tone 



Description 



Execution 

Encoding 
Script Example 



BEEP is exactly the same function as BEEP I except that 
the information used to produce the tone is stored in 
ROM and is referenced by the operand specified in this 
command. There are three predefined tones of one, two 
or three beeps with a duration of 500mS and a period of 
500mS. If the reference operand is out of the range of 1 - 
3, this command will be ignored. 

SFLAG <- 1 

NBEEPS <-BEEP[REF].NBEEPS 
NDUR <- BEEP[REF].NDUR 
NPER <- BEEP[REF].NPER 

(7lh][Reference Beep] ( 2 Bytes ) 

BEEP 2 



Produces two tones, 500rnS apart. 
500mS for each tone. 



for a duration of 



6 BEEP! produce an audible tone 



Description 



Execution 



BEEPI is used to produce an audible tone from the 
handheld terminal. Once this command is executed, the 
beep function will operate in the background allowing 
other instructions to be executed. There are two ways 
the beep function is terminated. First, the number of 
beeps specified in the command has expired; or second, 
a new program transaction has been received and 
execution of that program has started. The duration and 
period operands are defined to be lOOmS units of time, 
with a maximum time value of 25.5 seconds. 

SFLAG <-l 

NBEEPS <- Operand #1 
NDUR <- Operand #2 
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Encoding 
Script Example 

7 CLR clear register 
Description 
Execution 
Encoding 
Script Example 



8 DISABLE disables 



40 

NPER <• Operand #3 
[70hl[NBEEPS][NDUR][NPER] ( 4 Bytes ) 

BEEPI 2, 5, 5 

Produces two tones, 500mS apart, for a duration of 
500mS for each tone. 

The contents of the destination register is reset to zero. 
Rd <-0 

[20h][Rd] (2 Bytes) 
TO =0 

Rp.fnre Instruction 
TO - 100 
handheld terminal 



After Instruction 
TO-0 



Description 



Execution 
Encoding 
Script Example 



When this command is executed, the handheld terminal 
will be set to the uninitialized state. The unit will no 
longer respond to the IR receiver or keyboard input 
from the user except in the access control mode to 
reinitialize the handheld terminal. 

IFLAG <- 0 

[0A4h][Box Id] (5 Bytes) 
DISABLE 12345678 
Before Instruction 
IFLAG - 1 



After Instruction 
IFLAG -0 



,9 DISPLAY write formatted text to the display 



Description 



Delimiters 



Display - accepts a series of plain characters and 
delimiters in the string and outputs the formatted string 
to the display screen. The plain characters are copied 
verbatim to the display screen and the delimiters are 
used to specify the insertion of prestored strings, 
variables, end of display lines and end of display strings. 

NULL: Used to signify the end of a display string. When 
this character is encountered in the string, the formatted 
display string is transferred to the sixteen screen 
message buffer and becomes the active display message 
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in the buffer. The encoded byte value for the NULL 
character is 0. 

VARIABLE: Used to signify that an internal register 
value will be inserted into the formatted text string. The 
VARIABLE delimiter is composed of the delimiter, 
register number to be displayed and the format specifier. 
Tlie encoded byte value for the VARIABLE character is 
Olh, followed by the register number and the format 
specifier. A total of three bytes are needed to define this 
delimiter. 

The format specifier is composed of a four bit field 
defining the field width and a four bit field defining the 
field format The field width is located in the upper 
nibble of the byte and specifies a field width of 1 - 15 
characters. Refer to the table below for the definition of 
the field format located in the lower nibble. 

0 - Left justified integer 

1 - Right justified integer, blank padded 

2 - Right justified integer, zero padded 

3 - Reserved 

4 - Left justified fixed point integer 

5 - Right justified fixed point integer, blank padded 

6 - Right justified fixed point integer, zero padded 

7 - 15 Reserved 

MESSAGE: Used to insert any of the prestored 
messages available in ROM or non-volatile memory. 
When this delimiter is encountered, the current display 
line will be terminated and padded to 24 characters, if 
needed, and the prestored 'message specified will be 
inserted on the following display lines. The encoded byte 
value for the MESSAGE character is 02h ? followed by 
the prestored message number. A total of two bytes are 
needed to define this delimiter. 

CR: Used to signify the end of a display line. If 24 
characters where not specified for the current display 
line, the remainder of the display line will automatically 
be padded with blanks. The encoded byte value for the 
CR character is ODh. 

Encoding [0A5h][String] 

Script Example DISPLAY 'Thanks for playing! Tune in & play again 

soon!" 

Display Screen 

Line 1 - Thanks for playing! Tune 
Line 2 - in & play again soon! 

DISPLAY 'To get poll results,\rpress 'Yes 1 now." 
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Dis play Screen 

Line 1 - To get poll results, 

Line 2 - press 'Yes' now. 

DISPLAY "You have %i pointsArGreat work!", 
TSCORE 

Dis play Screen 

Line 1 - You have 20 points. 

Line 2 -Great work! 



10 PIY divide registers 
Description 

Execution 
Encoding 
Script Example 



The contents of the destination register are divided by 
the contents of the source register and the quotient is 
stored in the destination register. 



Rd <- Rd/Rs 
[82h][Rd][Rs] (3 Bytes) 
TO'=TO/T1 
Before Instruction 



TO - 113 
Tl - 10 



After Instruction 

TO -11 
Tl - 10 



11 DIVT divide register bv an immediate value 
Description 



Execution 
Encoding 
Script Example 



The contents of the destination register are divided by a 
32 bit immediate value and the quotient is stored m the 
destination register. 



Rd <- Rd/ Value 
[92h][Rd][Value] ( 6 Bytes ) 
T0=T0/20 
Before Instruction 
TO - 201 



After Instruction 
TO - 10 
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Description 

Execution 
Encoding 
Script Example 



43 



Deletes a PIU table from non-volatile memory allowing 
a different program to use that PIU table. All of the 
values in the PIU table are cleared. 

PIU[PID] <-0 

[0A0h][PID Number] ( 4 Bytes ) 
DELETE 112233 
Before Instruction 



PIU Table 
PID - 112233 
ESCORE - 10 
PSCORE-0 
TSCORE - 20 
RESP1 - 1 
RESP2 - 0 
RESP3 - 0 
FLAG - llh 

13 EXIT terminate program execution 

Description 



After Instruction 

PIU Table 
PID-0 
ESCORE - 0 
PSCORE - 0 
TSCORE - 0 
RESP1-0 
RESP2 - 0 
RESP3 - 0 
FLAG - 0 



Execution 
Encoding 
Script Example 



Used to signal to the control software that the active 
transaction is finished. 

TFLAG <-0 

[0A2h] ( 1 Byte ) 

EXIT 

Before Instruction After Instruction 

TFLAG - 1 TFLAG - 0 
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14 GO TO unconditional ~'»«ive branch 



Description. 



Execution 
Encoding 
Script Example 



Used to update the transaction pointer and transfer 
program control to the new program locauon stored in 
the transaction pointer. If the value being ^stored mthe 
transaction pointer is out of the current address range of 
KSroran the program will be halted. The offset used 
Sr ?ne^Sive biaSTis a 16 bit two's complement 

value- 
TP = TP + Offset 
[0A7h][Offset] (3 Bytes) 
GO TO LOOP 
Before Instruction 



TP - lOOOh 
LOOP - 9F0h 
OFFSET -OFFFOh 



After Instruction 

TP-9F0h 
LOOP - 9F0h 
OFFSET - OFFFOh 



15 IF conditional branch 
Description 



This instruction is used to form higher level^structs: 
IF IF - THEN, IF - THEN - ELSE and WHILE. The 
two operands are logically or arithmetically compared 
All comparisons are referenced to operand A. Operand 
B can be a register or an immediate value. 



If the logical or arithmetic comparison is true, the true 
offset will be added to the transaction pointer and 
program execution will be transfered to that new 
location. Otherwise, the false offset will be added to the 
transaction pointer. Below is a list of the available 
operators and their encoded values. 

OOh - ">", Greater Than 

01h-"<",Less Than 

02h - "> Greater Than or Equal to 

03h - *'< =", Less Than or Equal to 

04h -"==", Equal to 

05h -"!=", Not Equal to 

06h - "AND", Logical AND 

07h- "OR", Logical OR 

Encodine [A9h][Operatorl[Operand Al[Operand B][True 

kneomng Offsetl[False Offset] ( 8/13 Bytes ) 

Script Example IF ( RESP1 == TO ) THEN 
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16 INPUT input response 

Description Used to accept user input from the keyboard. The 

command can accept input from any location specified 
on the visible screen, specified by the X offset variable. 
The number of keys entered from the keyboard can be 
limited by the field width variable. If the field width 
variable is one, then an enter key is not needed to 
terminate an input response. If the timeout variable is 
non-zero, then the input response from the user will be 
timed and the remaining time will be displayed on the 
screen. If the timer expires, the input command will 
terminate automatically and the input buffer will contain 
a null string. 

There is one option available with the timed input 
response mode. The control program has the capability 
to display a decreasing score rather than time. This is 
achieved by specifying a register to decrement, a time to 
update the score and a value to decrement the register 
at every register update. The score will be displayed in 
the same location as the time. There is only a three 
character field to display the score within, so register 
values should not be greater than 999. If the initial 
register value to be displayed is greater than 999, then 
the input command will be terminated. 

The string that is specified with the input command has 
the exact same format as the string format for the 
display command. Refer to the display command for a 
definition of the string format. 

Encoding Timer Format 

[50h][Field Width][X offset][Timeout][String] 

Score Format 

[51h][Field Width][X offset][Timeout][Rs]pec.][Time 
Inc.] [String] 

Script Example INPUT "How much are you willing to bet?", 3,33 

INPUT "Enter your response\rnow? M , 1, 30, 10, 0, 5, 2 
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17 KEY define new d ^ryprion key 
Description 



Execution 
Encoding 
Script Example 



Wh^n executed, the 16 bit value specified will replace 
SSSfret #3. This will aBowa| subsequent 
transactions that were encrypted with KEY # 3 to be 
decrypted by KEY #3. This command does not delete 
SKSrogM- allowing other transacts to 
be decrypted by KEY #1 or KEY #2. 

KEY3 <- Value 

[0A3h][Value] (3 Bytes) 

KEY 1234 

Before Instruction 

KEY3 - 55AA 



Aftpr Instruction 
KEY3 - 1234 



1 8 LOCK Inck out user input 
Description 



Execution 
Encoding 
Script Example 



Used during a live interactive broadcast to terminate an 
input command. This should be the only command in the 
transaction except for a display or exit command. Ihe 
lock command does not operate on any register or 
memory location. It is basically a NOP command. The 
only function of this command is to terminate the 
currently executing program. 

Told <- Tnew 

[A8h] (iByte) 

DISPLAY "No more inputs at this\nime" 

LOCK 

EXIT 



19 MOD calculate remainder 



Description 

Execution 
Encoding 
Script Example 



The contents of the destination register are divided by 
the contents of the source register and the remainder is 
stored in the destination register. 

Rd <- Rd % Rs 

[83h][Rd][Rs] (3 Bytes) 

TO = TO % Tl 

Before Instruction 



TO - 113 
Tl - 10 



After Instruction 

TO - 3 
Tl - 10 
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20 MODI calculate remainder by an immediate value 
Description 



Execution 
Encoding 
Script Example 



21 MOV move register 
Description 

Execution 
Encoding 
Script Example 



The contents of the destination register are divided by a 
32 bit immediate value and the remainder is stored in 
the destination register. 

Rd <- Rd% Value 

[93h][RdJ[Value] ( 6 Bytes ) 

TO = TO % 20 

Before Instruction After Instruction 

TO - 201 TO - 1 



The contents of the destination register are loaded with 
the contents of the source register. 



Rd <- Rs 

[84h][Rd][Rs] ( 3 Bytes ) 
TO = Tl 

Before Instruction 



TO - 100 
Tl - 200 

22 MQVI load register with immediate value 
Description 



After Instruction 

TO - 200 
Tl - 200 



Execution 
Encoding 
Script Example 



The contents of the destination register are loaded with 
a 32 bit immediate value. 

Rd <- Value 

[94h][Rd][Value] ( 6 Byres ) 
TO = 1000 

Before Instruction After Instruction 

TO - 100 TO - 1000 
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•23 MPY m ultiply registers 
Description 



The contents of the destination register ; |« «^P"«J 
with the contents of the source register and the result is 
stored in the destination register 



Execution 
Encoding 
Script Example 



Rd <- Rd * Rs 
[85hl[Rd][Rs] ( 3 Bytes ) 
TO = TO * Tl 

Before Instruction 

TO - 100 
Tl-20 



After Instruction 

TO - 2000 
Tl-20 



24 MPYT multiply register with an imm ediate value 
Description 



Execution 
Encoding 
Script Example 



.25 OR or registers 
Description 

Execution 
Encoding 
Script Example 



The contents of the destination register are multiplied by 
a 32 bit immediate value and the result is stored in the 
destination register. 



Rd <- Rd * Value 
[95h][Rd][Value] ( 6 Bytes ) 
TO = TO * 100 
Before Instruction 
TO - 100 



After Instruction 
TO - 10000 



The contents of the destination register are ored with 
the contents of the source register and the result is 
stored in the destination register. 

Rd<-Rd ORRs 

[86h][Rd][Rs] (3 Bytes) 

T0=T0ORTl 

Before Instruction 



T0-8000h 
Tl - 7000h 



After Instruction 

TO-OFOOOh 
Tl - 7000h 
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26 ORI or register with immediate value 
Description 



The contents of the destination register are ored with a 
32 bit immediate value and the result is stored in the 
destination register. 



Execution 
Encoding 
Script Example 



Rd<-Rd OR Value 
[96h][Rd][Value] (6 Bytes) 
TO = TO OR 33h 
Before Instruction 
TO-8000h 



After Instruction 
TO - 8033h 



.27 PRESTORE store display string 



Description 



Execution 
Encoding 
Script Example 



Used to store a display string to one of the six prestored 
message buffers in non-volatile memory. The display 
string can have a maximum length of eight display lines 
and can have any of the string delimiters embedded in 
the string except'for the variable delimiter. If the string 
length is longer than eight display lines and the message 
number specified is not within the range of 6 - 10, then 
the command will be ignored. 

MSG[#] <- String 

[0A6h] [Message #][String] 

PRESTORE "Please try again", 6 

MSG[6] <- "Please try again" 



SUBSTITUTE SHEET 

9310605AI J > 



WO 93/10605 



PCT/US92/0945 



50 



28 RNG specify in put ranee 
Description 



Execution 

Encoding 
Script Example 



The contents of the low & high registers arc saved and 
used to execute input value range checking anytime an 
input command is executed. If the range pomnaod i was 
not specified, then all input commands * *e "w^t 
transaction will not be range checked. If toe input 
response is within the range, the processing of opcodes 
will continue. If the input response was entered for the 
first time the prestored message #2 will be displayed for 
two seconds and the user will be allowed to respond one 
more time after the display is restored. If the response 
was the second attempt the prestored message #3 will 
be displayed for two seconds and the input command 
terminated with a zero placed m the input buffer. The 
controller will begin executing opcodes after the input 
opcode. 

Low Range <- Rl 
High Range <- Rh 

[8Bh][Rl][Rh] ( 3 Bytes ) 

RANGE TO, Tl 

Before Instruction 

TO - 1 
Tl-2 
RL-10 
RH-20 
RFLAG - 0 



After Instruction 

TO - 1 
Tl-2 
RL - 1 
RH - 2 
RFLAG - 1 



.29 RNGT specify input range with im mediate values 



Description 



Execution 



The low & high 32 bit immediate values are saved and 
used to execute input value range checking anytime an 
input command is executed. If the range command was 
not specified, then all input commands in the current 
transaction will not be range checked. If the input 
response is within the range, the processing of opcodes 
will continue. If the input response was entered for the 
first time the prestored message #2 will be displayed for 
two seconds and the user will be allowed to respond one 
more time after the display is restored. If the response 
was the second attempt the prestored message #3 will 
be displayed for two seconds and the input command 
terminated with a zero placed in the input buffer. The 
controller will begin executing opcodes after the input 
opcode. 

Low Range <- Low Value 
High Range <- High Value 
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Encoding 
Script Example 



[0Alh][Low Value](High Value] ( 9 Bytes ) 
RANGE 1, 2 

Before Instruction Aftr.r Instruction 



RI_ - 10 
RH-20 
RFLAG-0 



RL- 1 
RH-2 
RFLAG - 1 



30 RSTF reset PIU flag bit 
Description 



This instruction resets a bit of the PIU flag register. The 
bit that is reset is specified in the instruction. 



Execution 
Encoding 
Script Example 



PIU[PID].FLAG[BIT] <- 0 
[00010b][xxx] ( 1 Byte ) 
RSTF 3 
B efore Instruction 
FLAG - FFh 
31 SETF sets PIU flae bit 
Description 



After Instruction 
FLAG - F7 



Execution 
Encoding 
Script Example 



This instruction sets a bit of the PIU flag register. The 
bit that is set is specified in the instruction. 

PIU[PID].FLAG[BIT] <- 1 

[00011b][xxx] ( i Byte ) 

SETF 3 

Before Instruction 
FLAG - lOh 



After Instruction 
FLAG - I8h 



32 SHL shift register left 
Description 

Execution 
Encoding 
Script Example 



The contents of the destination register are shifted left 
by the number of bits specified by the value in the source 
register. 

Rd <- Rd SHLRs 
[87h][Rd][Rs] (3 Bytes) 
TO = TO SHLT1 
Before Instruction 



After Instruction 
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TO - lOOOh 
Tl-3 



TO - 8000h 
Tl-3 



SHT.T shi " r oister lelt »T °" immediate value 
Description 



The contents of the destination register are shifted left 
by dumber of bits specified by the 32 bit immediate 
value. 



Execution 
Encoding 
Script Example 



Rd <- RdSHL Value 
[97h][Rd][Value] ( 6 Bytes ) 
T0=T0SHL8 
Before Instruction 
TO - lOOh 
14 SHR sb ^«" register right 
Description 



After Instruction 
TO - lOOOOh 



The contents of the destination register are shifted right 
by the number of bits specified by the value m the 
source register. 



Execution 
Encoding 
Script Example 



Rd <- RdSHRRs 

[88h][Rd][Rs] (3 Bytes) 

TO = TO SHR Tl 

Before Instruction 

TO - lOOOh 
Tl-3 



After Instruction 

TO - 200h 
Tl-3 



35 SHRI chit* register right bv immediate value 
Description 



The contents of the destination register are shifted right 
by the number of bits specified by the 32 bit immediate 
value. 



Execution 
Encoding 
Script Example 



Rd <- Rd SHR Value 
[98h][Rd][Value] ( 6 Bytes ) 
TO = TO SHR 8 
Before Instruction 
TO - lOOOh 



After Instruction 
TO - lOh 
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36 SUB subtract registers 
Description 



Execution 
Encoding 
Script example 



The contents of the destination register are subtracted 
from the contents of the source register and the result is 
stored in the destination register. 



Rd <-Rd-Rs 
[89h][Rd][Rs] ( 3 Bytes ) 
TO = TO - Tl 

Before Instruction 



TO - 100 
Tl -20 

37 SUB I subtract immediate value from register 
Description 



After Instruction 

TO - 80 
Tl - 20 



Execution 
Encoding 
Script example 



The contents of the destination register are subtracted 
by a 32 bit immediate value and the result is stored in 
the destination register. 



Rd <-Rd- Value 
[99h][Rd][Value] ( 6 Bytes ) 
TO = TO - 50 
Before Instruction 
TO - 100 



After Instruction 
TO - 50 



38 TTME verify real time 
Description 



Execution 



Encoding 



When this instruction is executed, the date and time of 
the real time clock is compared to the date and time 
specified with this instruction. Due to the potential for 
the real time clock to drift over time, the comparison will 
be made over a range of +- one minute. If the time of 
the handheld is out of this range, the unit will be set to 
it's uninitialized state and will no longer have the ability 
to process new transactions until it is reinitialized. If this 
instruction is used, it should be the First executable 
instruction in a transaction. 

If ( Real Time = = Time Stamp ) Then 
Process Transaction 
Else 

Disable Handheld 
[60h][TIME/DATE] ( 5 Bytes ) 

The encoded value of the year is the difference between 
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the present-year and the year 1990. Below is a table of 
the encoded date and time: 

Bvte#l-M1M0S5S4S3S2S1S0 
Byte #2 - H3 H2 HI HO M5 M4 M3 M3 
Bvtl #3 - Ml MO D4 D3 D2 Dl DO H4 
Byte #4 - Y5 Y4 Y3 Y2 Yl YO M3 M2 

TIME ©TIME, @DATE 

The current date and time variables ar evened by the 
RDI when it detects the time opcode. This is to insure 
that t£e realtime of the handheld should match the real 
time of the program being aired. 



39 XOR evHnsive or registers 
Description 



Execution 
Encoding 
Script Example 



The contents of the destination register ^e exclusive 
ored with the contents of the source register and the 
result is stored in the destination register. 

Rd <- Rd XOR Rs 
[8Ah][Rd][Rs] (3 Bytes) 
T0=T0XORTl 
Before Instruction 



TO - 8000h 
Tl - OCOOOh 



After Instruction 

TO - 4000h 
Tl - OCOOOh 



40 XQRI evrhisive or register wit h immediate value 
Description 



Execution 
Encoding 
Script Example 



The contents of the destination register are exclusive 
ored with a 32 bit immediate value and the result is 
stored in the destination register. 

Rd <-Rd XOR Value 

[9Ah][Rd][Value] (6 Bytes) 

TO = TO XOR 8033h 

Rftfnre Instruction After Instruction 

TO - 8000h TO - 33h 
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Table 3 
Prestored Messages 



Message #1 
Message #2 

Message #3 

Message #4 

Message #11 
Message #12 
Message #13 

Message #14 

Message #15 

Message #16 

Message #17 
Message #18 

Message #19 

Message #20 

Message #21 

Message #22 

Message #23 



Line 1 - Too Late! Try next time! 

Line 1 - Not a valid choiceAr 
Line 2 - Try again now! 

Line 1 - Still not valid.\r- 
Line 2 - Better luck next time! 

Line 1 - Press enter after your\r 
Line 2 - answer. 

Line 1 - Enter your choice now. 

Line 1 - Enter your answer now. 

Line 1 - Select your answer &\r 
Line 2 - then press "Enter" 

Line 1 - Sorry invalid answer. You 
Line 2 - have one more chance now 

Line 1 - Invalid answer.No answer 
Line 2 - will be accepted now. 

Line 1 - Good answer! You are\r 
Line 2 - right! 

Line 1 - Wrong answer. Too Bad! 

Line 1 - Good try! You can do\r 
Line 2 - better next time! 

Line 1 - Nice try! Better luck\r 
Line 2 - next time! 

Line 1 - Good score! You may be\r 
Line 2 - a winner! 

Line 1 - Enter answer before the\r 
Line 2 - time displayed runs out! 

Line 1 - The faster you answer,\r 
Line 2 - the higher you score! 

Line 1 - Not fast enough. Sorry. 
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Message #24 
Message #2S 
Message #26 

Message #27 

Message #28 

Message #29 

Message #30 

Message #31 

Message #32 

Message #33 

Message #34 

Message #35 
Message #36 
Message #37 
Message #38 
Message #39 
Message #40 
Message #41 
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Line 1 - Sony, too late. 

Line 1 - Thank you. 

Line 1 - Thanks for playing! Tune 
Line 2 - in & play again soon! 

Line 1 - Thanks for tuning in!\r 
Line 2 - Please join us again! 

Line 1 - Tune in and try again\r 
Line 2 - next time! 

Line 1 - To qualify to win, you\r 
Line 2 - must register your score 

Line 1 - To enter by mail, press\r 
Line 2 - "yes" now. 

Line 1 - To register your score\r 
Line 2 - by mail,press "yes" now. 

Line 1 - To save your score press 
Line 2 - "save" then 1,2 or 3;or\r 
Line 3 - write your score down\r 
Line 4 - now! 

Line 1 - To save this info,press\r 
Line 2 - "save" then 1,2 or 3;or\r 
Line 3 - write it down now. 

Line 1 - To save phone# pressVr 
Line 2 - "save" then 1.2 or 3;or\r 
Line 3 - write it down now. 

Line 1 - To get survey results,\r 
Line 2 - press "yes" now. 

Line 1 - To get poll results,\r 
Line 2 - press "yes" now. 

Line 1 - To get a copy of the\r 
Line 2 - rules,press "yes" now. 

Line 1 - Winners will be notified 
Line 2 - by certified mail. 

Line 1 - To get the list of\r 
Line 2 - winners,press "yes" now. 

Line 1 - To get your test results 
Line 2 - press "yes" now. 

Line I - To get your game score,\r 
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Line 2 - press "yes n now. 

Message #42 Line 1 - To get your score result 

Line 2 - press "yes" now. 

Message #43 Line 1 - You must be 12 or older\r 

Line 2 - to use 900#'s. 

Message #44 Line 1 - Parental consent needed\r 

Line 2 - if under 18 years old. 

Message #45 Line 1 - Must be 18 years or\r 

Line 2 - older to win. 

. Message #46 Line 1 - Void where prohibited by 

Line 2 - law 

Message #47 Line 1 - For more information^ 

Line 2 - press "yes" now. 

Message #48 Line 1 - For a summary of rules\r 

Line 2 - press "yes" now. 

Message #49 Line 1 - Welcome to a new TW 

Line 2 - experience! 

Message #50 Line 1 - Hello! We hope you are\r 

Line 2 - enjoying our program! 

Message #51 Line 1 - We're glad you're back! 
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We Claim: 



15 



1. An interactive presentation system 
comprising : 

5 means for receiving at a remote location 

interactive data in association with a presentation of 
an event; 

means for defining transaction structures (1) 
for allowing the interactive data to be communicated 
10 only as needed for each particular aspect of an event 
and throughout the event such that there is no 
interruption of the event and (2) for allowing events 
and aspects within any event to be interleaved while 
maintaining interactivity with each event; and 

means for reporting the results of the 
interactivity. 

2. The apparatus of claim 1 wherein said 

receiving means includes: 

a settop decoder for decoding interactive 
data received in conjunction with a signal for the 
event; 

a handheld terminal for allowing the user to 

interact with the event; and 
25 means for providing communications between 

the settop decoder and the handheld terminal. 

3. The apparatus of claim 1 wherein said 
transaction structures includes: 

30 means for storing an identification for each 

of a plurality of transaction tables; 

means for storing at least a portion of the 

interactive data; and 

means for storing a user response to the 

35 interactive data. 



20 
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4. The apparatus of claim 1 including: 
said interactive data includes (1) 

interactive commands and (2) event specific data 
associated with each specific event or aspect of each 
5 event; 

wherein said interactive data associated with 
each specific event or aspect of each event is stored 
in the transaction structures; and 

said system including processor means for 
10 processing the interactive commands in order to 
control the interactive presentation. 

5. The apparatus of claim 4 including: 
said receiving means including a message 

15 display; and 

said interactive commands in conjunction with 
the processor means for causing messages to be 
displayed on said message display. 

20 6. The apparatus of claim 5 wherein: 

said receiving means can receive messages to 
be displayed and said transaction structures can store 
received messages; and 

said interactive commands for causing 
25 selectively either a received message or a stored 
message to be displayed in order to initiate or 
continue with an interactive presentation. 

7. The apparatus of claim 1 including; 
30 said means for defining transaction 

structures for allowing one transaction to be used 
interactively by a user while a subsequent transaction 
is being received by the receiving means for 
subsequent use by the user. 

35 
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8. The apparatus of claim 1 including: 
said receiving means including means for 

decoding interactive data encoded in the vertical 
blanking interval of a television signal in order to 
receive the interactive data in association with the 
presentation of an event. 

9. The apparatus of claim 2 including: 
said communicating means including an 

infrared encoder and transmitter associated with the 
settop decoder and an infrared receiver and decoder 
associated with the handheld terminal. 

10. The apparatus of claim 1 including: 
said receiving means including means for 

receiving the interactive data at a high data rate and 
for substantially reducing the data rate so that the 
data can be accurately received by the transaction 
structures defining means. 



11. The apparatus of claim 1 including: 
said receiving means and said transaction 

structures defining means for additionally allowing 
the interactive data to be received in a manner that 
25 is transparent to a viewer of the event. 

12. An interactive presentation system 

comprising: 

means for receiving interactive data which 

30 includes commands and event specific data as needed 
according throughout the presentation of an event in 
accordance with the specific requirements of any 
particular aspect of the event; 

means for storing the event specific data; 



SUBSTITUTE SHEET 

BNSDOCID: <WO 931 060SA 1 _!_> 



WO 93/10605 



PCT/US92/094 



-77- 



means for acting responsive to the commands 
in order to use the event specific data to allow a 
viewer to interact with a presentation. 

5 13. The apparatus of claim 12 including: 

means for presenting messages; 

said means for acting upon said commands for 
causing the message presenting means to display at 
least one of a message sent in association with the 
10 commands and a message prestored as part of the event 
specific data. 

14. The apparatus of claim 12 including: 
said means for acting upon said commands for 

15 initiating and controlling the ability of the viewer 
to interact with a presentation and for controlling 
the event specific data. 

15. The apparatus .of 12 including: 

20 said means for storing event specific data 

including means for defining transaction structures 
(1) for allowing the interactive event specific data 
to be communicated only as needed for each particular 
aspect of an event and throughout the event such that 

25 there is no interruption of the event and (2) for 
allowing events and aspects within any event to be 
interleaved while maintaining interactivity with each 
event . 

30 16. The apparatus of claim 12 wherein: 

said receiving means includes a settop 
decoder for decoding interactive data received in 
conjunction with a signal for the event; 
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said storing means includes a handheld 
terminal for allowing the user to interact with the 
event; and 

means for providing communications between 
the settop decoder and the handheld terminal. 

17. The apparatus of claim 15 wherein said 
transaction structures includes: 

means for storing an identification for each 
of a plurality of transaction tables; 

means for storing at least a portion of the 
interactive event specific data; and 

means for storing a user response to the 
interactive event specific data. 

18. The apparatus of claim 12 including: 
a message display: and 

said commands in conjunction with the acting 
means for causing messages to be displayed on said 
message display. 

19. The apparatus of claim 15 wherein: 
said receiving means can receive messages to 

be displayed and said transaction structures can store 

25 received messages; and 

said commands for causing in conjunction with 
the acting means selectively either a received message 
or a stored message to be displayed in order to 
initiate or continue with an interactive presentation. 



15 



20 



30 



20. The apparatus of claim 15 including; 

said means for defining transaction 
structures for allowing one transaction to be used 
interactively by a viewer while a subsequent 
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transaction is being received by the receiving means 
for subsequent use by the viewer. 

21. The apparatus of claim 12 including: 
said receiving means including means for 
decoding interactive data encoded in the vertical 
blanking interval of a television signal in order to 
receive the interactive data in association with the 
presentation of an event. 



22. The apparatus of claim 12 including: 
said receiving means including an infrared 

encoder and transmitter and the storing means includes 
an infrared receiver and decoder for communicating 
15 data between the receiving means and the storing 
means . 

23. The apparatus of claim 12 including: 
said receiving means including means for 

20 receiving the interactive data at a high data rate and 
for substantially reducing the data rate so that the 
data can be accurately stored by the storing means. 

24. The apparatus of claim 12 including: 
25 said receiving means and said storing means 

for additionally allowing the interactive data to be 
received in a manner that is transparent to a viewer 
of the event. 
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